import Vue from 'vue'
// 类似reset.css重置样式
import 'normalize.css/normalize.css' // A modern alternative to CSS resets
// 导入element-ui组件
import ElementUI from 'element-ui'
// 导入element-ui样式
import 'element-ui/lib/theme-chalk/index.css'
// 导入element-ui语言包，多语言切换
// import locale from 'element-ui/lib/locale/lang/en' // lang i18n
// style样式
import '@/styles/index.scss' // global css

import App from './App'
import store from './store'
import router from './router'

// 引入注册的全局组件
import PluginsCompoments from '@/components/index'

// 执行icons下的index.js
import '@/icons' // icon
// 执行permission下的index.js
import '@/permission' // permission control

import i18n from '@/lang'

Vue.use(PluginsCompoments)
// 注册Element-ui中的组件
// set ElementUI lang to EN
// Vue.use(ElementUI, { locale })
// 如果想要中文版 element-ui，按如下方式声明
// Vue.use(ElementUI)

// 配置ElementUI的中英切换逻辑
Vue.use(ElementUI, {
  i18n: (key, value) => i18n.t(key, value)
})

// 导入全局自定义指令
import * as directive from '@/directive/index'
Object.keys(directive).forEach((item) => {
  Vue.directive(item, directive[item])
})

Vue.config.productionTip = false

new Vue({
  el: '#app',
  router,
  store,
  i18n,
  render: h => h(App)
})
